<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <title>员工管理</title>
    <#include "../common/link.ftl">
    <script>
       function moveAll(srcClass,targetClass) {
           //console.log($('#role > option' ));
           // 移动所有 option 到目标集合
           $('.' + targetClass).append($('.' + srcClass + " > option"));
       }
       function moveSelected(srcClass,targetClass) {
         // 移动选中的 option 到目标集合
           $('.' + targetClass).append($('.' + srcClass +" > option:selected"));
       }
       // 超级管理员设定框隐藏
       $(function () {
           var $roleDiv;
           var checked = $('#admin').prop('checked');
           if (checked){
               // 如果是超管,则在页面渲染完后隐藏权限设定框
               $roleDiv = $('#role').detach();
           }
           $('#admin').click(function () {
               // 获取复选框的状态,如果勾选,删除权限设定框 tr
               var checked = $(this).prop('checked');
               //console.log(checked);
               if (checked){
                    $roleDiv = $('#role').detach();
               }else {
                   // 如果不勾选,恢复权限设定框
                    $('#adminDiv').after($roleDiv);
               }
           });

           var ids=[];
           // 遍历右边 option,存入数组中
           $('.selfRoles > option').each(function (i,domEle) {
               ids.push($(domEle).val());
           });
           // 遍历左边的 option 与 数组中的 option 比较
           $('.allRoles > option').each(function (i,domEl) {
               //console.log(i,domEl);
               // 与右边的 option 对比,存在则删除
               var $option = $(domEl);
               //console.log($option.val());
               if ($.inArray($option.val(),ids)>=0){
                   $(domEl).remove();
               }

           });
           // 选中其他的 option 也要提交,防止只提交选中的那个 option
           $('#submitBtn').click(function () {
               // 选中右边所有 option
               $('.selfRoles > option').prop('selected',true);
               // 提交表单
               $('#editForm').submit();
           });
           // 表单验证
           $("#editForm").bootstrapValidator({
               feedbackIcons: { //图标
                   valid: 'glyphicon glyphicon-ok',
                   invalid: 'glyphicon glyphicon-remove',
                   validating: 'glyphicon glyphicon-refresh'
               },
               fields:{ //配置要验证的字段
                   name:{
                       validators:{ //验证的规则
                           notEmpty:{ //不能为空
                               message:"用户名必填" //错误时的提示信息
                           },
                           stringLength: { //字符串的长度范围
                               min: 1,
                               max: 5
                           }
                       }
                   },
                   password:{
                       validators:{
                           notEmpty:{ //不能为空
                               message:"密码必填" //错误时的提示信息
                           },
                       }
                   },
                   repassword:{
                       validators:{
                           notEmpty:{ //不能为空
                               message:"密码必填" //错误时的提示信息
                           },
                           identical: {//两个字段的值必须相同
                               field: 'password',
                               message: '两次输入的密码必须相同'
                           },
                       }
                   },
                   email: {
                       validators: {
                           emailAddress: {} //邮箱格式
                       }
                   },
                   age:{
                       validators: {
                           between: { //数字的范围
                               min: 18,
                               max: 60
                           }
                       }
                   },
                   name:{
                       validators:{
                           remote: { //远程验证
                               type: 'POST', //请求方式
                               url: '/employee/checkName.do', //请求地址
                               data: function() {  //自定义提交参数，默认只会提交当前用户名input的参数
                                   return {
                                       id: $('[name="id"]').val(),
                                       name: $('[name="name"]').val()
                                   };
                               },
                               message: '用户名已经存在', //验证不通过时的提示信息
                               delay: 1000 //输入内容2秒后发请求
                           }
                       }
                   }
               }
           }).on('success.form.bv', function() { //表单所有数据验证通过后执行里面的代码
               //提交异步表单
               $("#editForm").ajaxSubmit(listHandlerMessage);
           });
           // 解决两次点击编辑问题
           <#if employee??>
           $('html').one('mouseover',function() {
               //每次弹框弹起后都会进行一次校验，而且只校验一次
               $('#editForm').data("bootstrapValidator").validate();
           });
        </#if>
       });

    </script>
</head>
<body class="hold-transition skin-blue sidebar-mini">
<div class="wrapper">
    <#include "../common/navbar.ftl">
    <!--菜单回显-->
    <#assign currentMenu = "employee"/>
    <#include "../common/menu.ftl">
    <div class="content-wrapper">
        <section class="content-header">
            <h1>员工编辑</h1>
        </section>
        <section class="content">
            <div class="box">
                <form class="form-horizontal" action="/employee/saveOrUpdate.do" method="post" id="editForm">
                    <input type="hidden" value="${(employee.id)!}" name="id" >
                    <div class="form-group" style="margin-top: 10px;">
                        <label for="name" class="col-sm-2 control-label">用户名：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="name" name="name" value="${(employee.name)!}" placeholder="请输入用户名">
                        </div>
                    </div>
                        <#if !(employee)??>
                        <div class="form-group">
                            <label for="password" class="col-sm-2 control-label">密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="password" name="password" placeholder="请输入密码">
                            </div>
                        </div>
                        <div class="form-group">
                            <label for="repassword" class="col-sm-2 control-label">验证密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="repassword" name="repassword" placeholder="再输入一遍密码">
                            </div>
                        </div>
                    </#if>
                    <div class="form-group">
                        <label for="email" class="col-sm-2 control-label">电子邮箱：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="email" name="email" value="${(employee.email)!}" placeholder="请输入邮箱">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="age" class="col-sm-2 control-label">年龄：</label>
                        <div class="col-sm-6">
                            <input type="text" class="form-control" id="age" name="age" value="${(employee.age)!}" placeholder="请输入年龄">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="dept" class="col-sm-2 control-label">部门：</label>
                        <div class="col-sm-6">
                            <select class="form-control" id="dept" name="dept.id">
                                    <#list departments as department>
                                    <option value="${department.id!}"
                                                ${((employee.dept.id == department.id)?string('selected',''))!}
                                    >${department.name}</option>
                                </#list>
                                <script>
                                    $('#dept').val(${(employee.dept.id)!});
                                </script>
                            </select>
                        </div>
                    </div>
                    <div class="form-group" id="adminDiv">
                        <label for="admin" class="col-sm-2 control-label">超级管理员：</label>
                        <div class="col-sm-6"style="margin-left: 15px;">
                            <input type="checkbox" id="admin" name="admin" class="checkbox">
                                <#if (employee.admin)!false>
                                <script>
                                    $("#admin").prop("checked", true);
                                </script>
                            </#if>
                        </div>
                    </div>
                    <div class="form-group " id="role">
                        <label for="role" class="col-sm-2 control-label">分配角色：</label><br/>
                        <div class="row" style="margin-top: 10px">
                            <div class="col-sm-2 col-sm-offset-2">
                                <select multiple class="form-control allRoles" size="15">
                                        <#list roles as role>
                                        <option value="${role.id}">${role.name}</option>
                                    </#list>
                                </select>
                            </div>

                            <div class="col-sm-1" style="margin-top: 60px;" align="center">
                                <div>
                                    <a type="button" class="btn btn-primary  " style="margin-top: 10px" title="右移动"
                                       onclick="moveSelected('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-menu-right"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="左移动"
                                       onclick="moveSelected('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-menu-left"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全右移动"
                                       onclick="moveAll('allRoles', 'selfRoles')">
                                        <span class="glyphicon glyphicon-forward"></span>
                                    </a>
                                </div>
                                <div>
                                    <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全左移动"
                                       onclick="moveAll('selfRoles', 'allRoles')">
                                        <span class="glyphicon glyphicon-backward"></span>
                                    </a>
                                </div>
                            </div>

                            <div class="col-sm-2">
                                <select multiple class="form-control selfRoles" size="15" name="ids">
                                        <#list (employee.roleList)! as role >
                                        <option value="${role.id}">${role.name}</option>
                                    </#list>
                                </select>
                            </div>
                        </div>
                    </div>

                    <div class="form-group">
                        <div class="col-sm-offset-1 col-sm-6">
                            <button id="submitBtn" type="button" class="btn btn-primary">保存</button>
                            <button type="reset" class="btn btn-danger">重置</button>
                        </div>
                    </div>
                </form>
            </div>
        </section>
    </div>
    <#include "../common/footer.ftl">
</div>
</body>
</html>
